public class Main {
    public static void main(String[] args) {
        int[] array1 = {1, -2, 3, 5, -1};
        System.out.println("Max subarray sum is: " + maxSubArraySum(array1));

        int[] array2 = {1, -2, 3, -8, 5, 1};
        System.out.println("Max subarray sum is: " + maxSubArraySum(array2));

        int[] array3 = {1, -2, 3, -2, 5, 1};
        System.out.println("Max subarray sum is: " + maxSubArraySum(array3));
    }

    public static int maxSubArraySum(int[] nums) {
        if (nums == null || nums.length == 0) {
            return 0;
        }

        int maxSoFar = nums[0];
        int currentMax = nums[0];

        for (int i = 1; i < nums.length; i++) {
            currentMax = Math.max(nums[i], currentMax + nums[i]);
            maxSoFar = Math.max(maxSoFar, currentMax);
        }

        return maxSoFar;
    }
}